Solution Review: Problem Challenge 3
We'll cover the following
Rotation Count (medium) #
Given an array of numbers which is sorted in ascending order and is rotated ākā times around a pivot, find ākā.
You can assume that the array does not have any duplicates.
Example 1:
Input: [10, 15, 1, 3, 8]
Output: 2
Explanation: The array has been rotated 2 times.
Example 2:
Input: [4, 5, 7, 9, 10, -1, 2]
Output: 5
Explanation: The array has been rotated 5 times.
Example 3:
Input: [1, 3, 8, 10]
Output: 0
Explanation: The array has not been rotated.
Solution #
This problem follows the Binary Search pattern. We can use a similar strategy as discussed in Search in Rotated Array.
In this problem, actually, we are asked to find the index of the minimum element. The number of times the minimum element is moved to the right will be equal to the number of rotations. An interesting fact about the minimum element is that it is the only element in the given array which is smaller than its previous element. Since the array is sorted in ascending order, all other elements are bigger than their previous element.
After calculating the middle
, we can compare the number at index middle
with its previous and next number. This will give us two options:
- If
arr[middle] > arr[middle + 1]
, then the element atmiddle + 1
is the smallest. - If
arr[middle - 1] > arr[middle]
, then the element atmiddle
is the smallest.
To adjust the ranges we can follow the same approach as discussed in Search in Rotated Array. Comparing the numbers at indices start
and middle
will give us two options:
- If
arr[start] < arr[middle]
, the numbers fromstart
tomiddle
are sorted. - Else, the numbers from
middle + 1
toend
are sorted.
Code #
Here is what our algorithm will look like:
Time complexity #
Since we are reducing the search range by half at every step, this means that the time complexity of our algorithm will be where āNā is the total elements in the given array.
Space complexity #
The algorithm runs in constant space .
Similar Problems #
Problem 1 #
How do we find the rotation count of a sorted and rotated array that has duplicates too?
The above code will fail on the following example!
Example 1:
Input: [3, 3, 7, 3]
Output: 3
Explanation: The array has been rotated 3 times
Solution
We can follow the same approach as discussed in Search in Rotated Array. The only difference is that before incrementing start
or decrementing end
, we will check if either of them is the smallest number.
Time complexity
This algorithm will run in most of the times, but since we only skip two numbers in case of duplicates instead of the half of the numbers, therefore the worst case time complexity will become .
Space complexity #
The algorithm runs in constant space .